package com.javaxiaobear.module.monitor.domain;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.javaxiaobear.base.framework.aspectj.lang.annotation.Excel;
import com.javaxiaobear.base.framework.aspectj.lang.annotation.Excel.ColumnType;
import com.javaxiaobear.base.framework.web.domain.SimpleEntity;
import com.mybatisflex.annotation.Column;
import com.mybatisflex.annotation.Id;
import java.util.Date;
import lombok.Data;
import lombok.EqualsAndHashCode;

/**
 * 操作日志记录表 oper_log
 *
 * @author javaxiaobear
 */
@EqualsAndHashCode(callSuper = true)
@Data
public class SysOperLog extends SimpleEntity {

  /** 日志主键 */
  @Excel(name = "操作序号", cellType = ColumnType.NUMERIC)
  @Id
  private Long operId;

  /** 操作模块 */
  @Excel(name = "操作模块")
  private String title;

  /** 业务类型（0其它 1新增 2修改 3删除） */
  @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据")
  private Integer businessType;

  /** 业务类型数组 */
  @Column(ignore = true)
  private Integer[] businessTypes;

  /** 请求方法 */
  @Excel(name = "请求方法")
  private String method;

  /** 请求方式 */
  @Excel(name = "请求方式")
  private String requestMethod;

  /** 操作类别（0其它 1后台用户 2手机端用户） */
  @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户")
  private Integer operatorType;

  /** 操作人员 */
  @Excel(name = "操作人员")
  private String operName;

  /** 部门名称 */
  @Excel(name = "部门名称")
  private String deptName;

  /** 请求url */
  @Excel(name = "请求地址")
  private String operUrl;

  /** 操作地址 */
  @Excel(name = "操作地址")
  private String operIp;

  /** 操作地点 */
  @Excel(name = "操作地点")
  private String operLocation;

  /** 请求参数 */
  @Excel(name = "请求参数")
  private String operParam;

  /** 返回参数 */
  @Excel(name = "返回参数")
  private String jsonResult;

  /** 操作状态（0正常 1异常） */
  @Excel(name = "状态", readConverterExp = "0=正常,1=异常")
  private Integer status;

  /** 错误消息 */
  @Excel(name = "错误消息")
  private String errorMsg;

  /** 操作时间 */
  @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
  private Date operTime;

  /** 消耗时间 */
  @Excel(name = "消耗时间", suffix = "毫秒")
  private Long costTime;
}
